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(57) Abstract: The invention is concerned with a method of downloading software into a radio terminal having at least two pieces 
of die software, one of which works as die current version. The capability of functioning of die current version of the software in 
the radio terminal is determined when die terminal is turned on. Another version of the software is downloaded if it is notified that 
there is a new version or if the current version does not work. If the current version is working, it is stored before a new version is 
downloaded. The capability of functioning of a current version of the software is tested before use. The result of the test is indicated 
in such a form mat die capability of functioning of said tested version of the software can be deternnned. The invention is also 
concerned with a radio terminal comprising means to carry out the method of the invention. 
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METHOD AND APPARATUS OF DOWNLOADING INTO A RADIO TERMINAL 

TECHNICAL FIELD 

, The invennon is concent with a method and apptuatus of dowMoading software inK, 
. rodio lertninal, eg. » mobile .»»■«■ *» more particularfy « is crmceroed wrfo 
remotely upgrading of software. 

10 DESCRIPTION OF BACKGROUND ART 

M° ^duals are typically programmed wifo swo pieces of the softvrare. a flta 
piece is hard coded in a programmable read only memory (PROM) and a second, 
L^Ie piece is landed into flash Programme Read Only Memm, (flash- 
l5 PROM). The software loaded in the liash-PROM may be periodically upgraded. 

^.oewveraionsofprogran. remade repn^ly and therefore there are tnefoods 
^ .pp^roses to reprograro radio renninrds, such aa ceUnlar telephones, temotd, 
^ . witeless connnunicauon link. I. is trov^uaif snchntemodat«ain*eold 
„ soft^unflu^rwradedsoflwtnebrcb^ 

In the international patent; application WO 98/381120 of the applicant, there is 
, tttefood and radio appararos for downtoading roftw« itfo a remotdy 
located cellular telephone via wireless communication. The ceUulnr telephone of this 
tadudes two memories for aoriog softvrare wiro on. memory stems foe 
softw-e and foe second memoty avmlable for downloaltng new softvrftre. The 
eoUutar telephcoe also includes a conrtoller for loading the received softwnr. tnro foe 
eeUttte mtephon. and for performing a checksum on the new software to control me 
^ for amending foe new software into .he phone. If the calculamd checksum 
toes oo, mtueh foe tronsmifted checksum, a teu^snsission of foe new software ts 



25 



30 



carried out 



b some snuadons U is extremely important font foe radio rerotinal. especially if it is a 
orobile phone, is funedoning. eg. in situations of emtrtgenc, calls fort ; foe user s 
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security, The software therefore has to be very robust When the soft^oSS 
downloaded over a wireless or other network, and updated in the radio terminal, it is 
possible that a new version contains bugs and will perhaps not start properly or even 
not start at all. This might be the case when the software is written by a third party. 
Moreover, the software could be quite advanced, so it could be hard to tell, from a 
programmer's view, when the application really has been started, even if a checksum 
process for the downloading process itself has been carried out Even if a version is 
supposed to work, the program itself might have been corrupted in some way. The 
checksum only controls if the program sent from the server still is in the same form 
when received by the radio terminal. If the program has bugs at the server, the same 
bugs are transferred to the radio terminal. 

If a version of the software that has been installed appears not to work, there should be 
some method to obtain a working version. There is also a problem with knowing 
when the application software has been started successfully. 



20 



SUMMARY OF THE INVENTION 

One object of the invention is a method and apparatus with which the user always 
knows if the current software in the radio terminal is functioning. 



Another object of the invention is a method and apparatus of downloading and 
installing software into the radio terminal in such a way that the above object is 
25 fulfilled. 

The method of the invention is therefore mainly characterized in that the capability of 
functioning of the current version of the software in the radio terminal is determined. 
Optionally, a possible existence of a new version of the software is then notified 
30 before or after said determination. As a possible result of said determination and/or 
said notifying, another version is selected to be downloaded, if according to said 
toerniination, the current version of the software does not work, another version of 
the software wili be downloaded. Before another version is downloaded, the current 
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version of the software is preferably stored if it is a working version accordingIM&& 
determination. The selected version of the software is downloaded into the radw 
terminal to be the current version if there according to said determination or said 
notifying is a reason thereto. The capability of functioning of the version of the 
software, that now is the current version in the radio terminal, is then tested. As is 
indicated above, the current version might be the one which was in the terminal in the 
beginning, when the terminal was turned on, it can be another version or it can be a 
new version. The result of said test is indicated in such a form that the capability of 
functioning of said tested version of the software can be determined. 

Thus, the invention also covers the methods, wherein the step of notifying the 
existence of a new version is excluded as weU as methods wherein this step is a 
necessary step. 

One version can alternatively also be tested more than once, before another version is 
installed. 

The apparatus of the invention is mainly characterized by means for determination the 
capability of functioning of the current version of the software in the radio terminal, 
notifying a possible existence of a new version of the software, selecting another 
version of software to be downloaded to replace the current version, storing the 
current version of the software, downloading another version of the software into the 
radio terminal to be the current version, testing the capability of functioning of me 
actual current version of the software, and of indicating the result of said test in such a 
form that the capability of functioning of said tested version of the software can be 
determined. 



In this application the term "downloading" means both remotely downloading and 
installing and reinstalling and reloading from another memory. The term "current 
30 version" means the active version of software in the terminal. The other versions 
stored are inactive. It is pointed out that when a new version is available it is not 
necessary to download it immediately. If it is downloaded it is not necessary to start it 
immediately and it can be done later on, for example the ; next time the terminal is 
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turned on. Furthermore, the new version of the software can be a later version 4ffefeS. 
software, a better version or an unproved version. The idea is that the possible 
existence of a "new" version is notified so that it would be possible to download some 
version wished which is not already stored in the terminal. 

5 

In the following there are presented some further, preferable characteristics for the 
method and apparatus of the invention 

When the radio terminal is turned on, the first thing that preferably is done is to 
10 determine if the current version of the software is functioning. The determination can 
be done by identifying the presence or absence of an indicator that shows the software 
situation, and has been inserted in the terrninal. The indicator can be the result of said 
test, which is indicated by the presence or absence of a special indicator that can be 
handled by an object in the program. 

The sign can be a persistent object If the object exists, it is known that the previous 
boot for downloading a new version of the software or the installing of another 
version failed. Such an embodiment is also possible, wherein the absence of the sign 
means that the current version does not work. A version that is supposed to work is 
20 then installed and the method can be repeated immediately or later until the result of 
the test shows that the current version of the terminal is working. The method can also 
be repeated the next time the radio tenninal is turned on, preferably each time the 
terminal is turned on. 

25 Said other version of the software can be an earlier stored older version, preferably the 
foregoing version used. The number of versions to be stored is selected by deleting 
one or more of the older versions, preferably according as new versions are installed. 

Said other version selected to be downloaded can be a new version of the software if 
30 such a new version exist according to said notifying. The other version of the software 
selected to be downloaded is an earlier stored older version, if the current active 
version is not working according to said determination and if there is no new version 
or the new version is not wished to be installed. 
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If the persistent object exists when the system is booted up (or in the alternative 
embodiment, does not exist), it is a sign of that something went wrong the last time. 
As explained above, a working version is then installed to be the current version or the 
version is tested at least once more. 

In one embodiment, said other version of the software to be installed as the current 
version can be a basic version stored in ROM or can be downloaded from the 
manufacturer's server if none of the stored older versions or the current version 
works. In some embodiments, there might be an option that the basic version can 
always be installed, if wished 

As indicated above, the result of said test is indicated by the presence or absence of a 
special indicator to show the software situation in the mobile phone by means of 
which indication the capability of functioning of the current version of the software in 
the mobile phone is notified. 

When the capability of functioning of said instaUed/downloaded version of the 
software is presented by the absence of said special indicator and the opposite 
situation with the presence of said indicator, in one embodiment of the invention the 
indicator is removed, when according to the test, a working version of the software 
has been started. In another embodiment said indicator is updated every time the 
functionality test is carried out to show the number of tests performed or to identify 
the current version of the software. 

The other version of software selected to be downloaded can be selected on the basis 
of the updated indicator. If the indicator for example shows that the test has been 
carried out many times, it may be advisable to reload a basic version of the software. 



30 



Thus, in one embodiment of the invention, instead of deleting the object when a test is 
passed and then creating a new one in the next test, the existing object is updated to 
give information of number of tests performed, of the actual version of the software 
etc. It can be decided in forward how many times a program shall be tested before 
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another or a basio version shall be installed. If the indicator shows up more thadftflS, 
h usually indicates that something else is wrong and in that case it might be preferable 
to install the basic first version mentioned above already in this stage. Something 
might for example have gone wrong when the program was stored in the memory. In 
5 case of a thud party code, another program might have destroyed the actual version. 
The copying of files in the radio terminal is a further possible reason. It can therefore 
also be advisable to test the same program more than once before installing an earlier 
version or the basic version. 

10 Said special indicator can be made in such a form that the actual version of the 
software can be identified and it can be in form of an ordinary file. 

The capability of functioning of said version of the software is tested by setting a 
number of checkpoints the software should pass to start up correctly as a working 

15 version. Each checkpoint can for example be a critical point per thread in the software 
or per terminal resource in the software that has to be passed. A resource can be a 
network, a file system, sound, etc. Other alternatives are also possible and they are 
chosen depending on the program. A checkpoint counter can be used for counting the 
checkpoints passed, the number of passed checkpoints can be checked, and the special 

20 sign can be deleted or updated if the number of checkpoints in the counter is equal to 
the number of checkpoints to be passed. 

The current version can be stored by packing it with a compressing program to reduce 
the amount of space required on the phone, for example the zip program. 

25 

The problem with knowing whether a new version of the software has successfully 
started is thus solved in the invention by having an indicator, that either exists or not, 
depending on the functionality of the software. The indicator will be deleted if the 
new version has started or in an alternative embodiment, is retained if the new version 
30 has started. 

With the method and apparatus of the invention, one can always be sure to have a 
working version and the system is; very robust 
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The tenninal of the invention can be a computer or a mobile phone or the like. 

In the following, the invention is described more in detail by means of four flow 
schemes and a schematic view. It is pointed out that these descriptions only are 
examples of embodiments of the invention and that the details of the inventions can 
vary within the scope of the claims. 

BRIEF DESCRIPTION OF THE DRAWINGS 
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Figure 1 illustrates a schematic view of an apparatus for downloading software into a 
radio terminal 

Figure 2 is a general flow scheme of the invention. 

Figure 3 is a flow scheme of two examples of a procedure in accordance with the 
15 invention. 

Figure 4 is a more detailed example of an embodiment of the invention. 
Figure 5 is a detailed example of steps 5,8 and 9 of figure 2 



DETAILED DESCRIPTION OF THE DRAWINGS 
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In figure 1 , there is illustrated an example of an apparatus for remotely downloading 
software into a radio terminal 1 0. An update server processor 1 1 communicates with a 
network 12, which has a wireless communication link 13 to the radio terminal 10. 
New versions of software are sent from the update server processor 1 1 via the network 
25 12 and the wireless communication link 13 to the. radio terminal 10 through the 
antenna 14. In addition to the normal functions of a radio tenninal, the tenninal 10 in 
figure 1 contains a transceiver 15, a controller 16, a first memory 17 and a second 
memory 18. The downloading of software from the update server 1 1 to the radio 
terminal 10 is carried out through the antenna 14 via the controller 15 to one of the 



30 memories. 



When a new version of the software is available, the update server processor 1 1 can 
transmit a message to the radio terminal 10 under control of controller 16, which can 
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either choose to download the new version or not in accordance with the iml&fife2 
The availability of new versions of software can also be known for the radio terminal 
1 0 so that the radio terminal 1 0 ask the update server 1 1 about the existence of a new 
version. The downloading itself is usually carried out by means of messages between 
5 server processor 11 and radio terminal 10. The update processor 11 can also send 
older versions of the software to the radio terminal 10 in accordance with the 
invention. 

When a new version has been downloaded in the terminal, it is considered as the 
10 current version, the capability of functioning of which is tested in connection with the 
starting of the program. The starting process of the software is followed up through a 
number of checkpoints the software should pass in a correct start A checkpoint 
counter can be used for counting the checkpoints passed, the number of passed 
checkpoints can be checked, and a special indicator can be created, deleted or updated 
15 in dependence of the number of checkpoints in the counter being equal to the number 
of checkpoints to be passed. 

In figure 2 there is presented a detailed embodiment of the invention by means of a 
flow scheme. One way of proceeding in the invention is by following the unbroken 
20 arrows. Alternative ways of proceeding are indicated with dotted arrows. In some 
embodiments, the alternatives can be selected in accordance with predefined criteria. 

Preferably, the method is carried out each time the terminal is turned on in accordance 
with reference number 1. In figure 2, the first dung to do is to check if me current 
25 version of the software is a working version as indicated with step 2 in the figure. This 
determination, based on the checking, is in accordance with figure 1 carried out by 
means of the indication of a test result, the test having been carried out in accordance 
with step 8 and the indication in accordance with step 9 explained below. The 
changing of information between the indication of the test result of step 9 and the 
30 checking of step 2 is indicated with a two-way arrow 3. The indication of the test 

result can be performed in many ways. It can be a sign in form of a persistent object 

that is an ordinary file. 
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If the current version, according to the test result indication of step 9 t appeailfti8§1& 
work, it means that something went wrong in the previous boot of the software. Step 
4a can now be carried out, according to which another version that is supposed to 
work is installed. This version might be an earlier stored working version of the 
5 software or it can even be a basic version stored in ROM or it can even be 
downloaded from the server of the manufacturer. If the current version appears not to 
work, it can "also be tested once more in steps 8 and 9. This alternative way is 
presented with a dotted arrow in the figure. 

10 If the current version in accordance with the test result presentation of step 9 is a 

working version considered in step 2, then, it is in step 4b of figure 2 checked if there 
is a new version existing. The alternative of not checking for a new version is 
indicated with a dotted arrow, and in that case the current version is started as 
indicated in step 5 . The capability of functioning of the current version is tested as 

15 indicated in step 8 when the software is started in checkpoints set in 

the program. 

It is possible to download a new version of the software even if there is no earlier 
version in the radio terminal, but this embodiment is not illustrated In that case, the 
20 first step in the invention is to download the new version, which then is started and 
tested and the test result is indicated as is described. 

If there is no new version (or it is not downloaded), the current version is started as 
indicated in step 5, and tested, as indicated in step 8. 

25 

The alternative of not downloading the new version of the software is indicated with a 
dotted arrow. 

If there is a new version, the current version is in figure 2 stored in step 6 and the new 
30 version is downloaded in step 7. 

For the new version downloaded in step 7 a functionality test is performed in 
connection with starting up as indicated in steps 5 and 8. 
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The capability of functioning of the downloaded or installed version of the software is 
tested as indicated in step 8 by setting a number of checkpoints the software should 
pass to start up correctly as a working version. A checkpoint counter can be used for 
5 counting the checkpoints passed, the number of passed checkpoints can be checked, 
and the special sign can be deleted or updated if the number of checkpoints in the 
counter is equal to the number of checkpoints to be passed. 

The result of the test is indicated in step 9 in such a form that the capability of 
10 functioning of a current version of the software always can be determined. Therefore, 
the result of said test is indicated by the presence or absence of a special indicator or 
sign to show the software situation in die terminal by means of which indication the 
capability of functioning of the current version of the software in the terminal is 
notified. 

15 

A new downloaded version or an installed version is tested in step 8 in connection 
with the starting of the program. There are, however, checkpoints embedded, and if 
these checkpoints are not passed, it shall appear in the presentation of the test result 

20 Figure 3 is a detailed flow scheme of two examples of how the method of the 
invention might proceed. It has to be pointed out that the downloading procedure 
depends on how the software in the terminal works and on the availability of new 
versions why the example is not intended to restrict the invention in anyway, but is 
shown for illustrating purposes only. 

25 

The terminal is turned on in accordance with reference number 100. In this 
embodiment, the* indication of the test result is performed in form of a persistent 
object, the existence of which shows that the current version of the software in the 
terminal is not working. 

30 

In figure 3, step 200 shows in the first example shown in figure 3 that the object 
exists, which means that something went wrong in the previous boot of the software. 
Step 400 al can now be carried out, according to which another version that is 
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supposed to work is installed. This version might be an earlier stored working VMEb3 0 
of the software or it can even be a basic version stored in ROM or it can even be 
downloaded from the server of the manufacturer. The downloaded version is started in 
step 500 whereby a new persistent object is created. In step 800:2, the downloaded 
version is tested and, since the test is passed, the persistent object is deleted in step 
900:2. 

Returning now to step 200, the absence of a persistent object in the second example 
causes the program to execute step 400 b, whereby it is now checked if there is a new 
version existing. Since there is a new version, the current version is stored in step 600 
and the new version is stored in step 700 to be the current version. The new version is 
started in step 800:1 hereby a persistent object is created and a number of checkpoints 
to be passed is set In step 900:1, the new version is tested. As this version did not 
start up correctly, actions are taken in step 400:a2 to remedy the fault by for example 
by going to step 400al and by proceeding as was explained in the first example. 

Other alternatives are discussed in the following. For example, the user of the terminal 
may conclude, from an improper program behaviour, that something is wrong and 
restart the terminal by first turning it off and immediately thereafter turning it on again 
which effectively means to turn to step 100. It is also possible that the program 
execution is terminated and control is handed over to the kernel whereby the number 
of passed checkpoints may be checked. Automatic actions may thai be executed in 
response to a mismatch between the preset counter value and die number of passed 
checkpoints. It is also possible to implement a low level interrupt in step 800, whereby 
the kernel may detect that the program execution has stopped or entered into a loop. 
The kernel may then, in step 400^2, execute automatic actions to remedy the fault, 
e.g. restart the program execution from step 200. If the kernel can take control, the 
automatic actions in case of a faulty program can be varied. For example the kernel 
may indicate to the user that a program error has been detected but that certain 
functions will be allowed. The user may, e.g., be allowed to manage a local calendar 
whereas a network connection may not be allowed. The kernel may determine which 
functions of the program that are working from an analysis of data compiled from the 
checkpoints having been passed. 
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In figure 4, there is shown a detailed example of an embodiment of the invention. 
In the figure, the different steps corresponding to the steps of figure 2 have been 
indicated with corresponding reference number, as in figure 2, except that m this 
embodiment, the upper indexes < and " and "' is used to mdicate thus special 
embodiment Lower mdex^^^ 

different steps in themselves have been earlier explained in the text, and the intention 
with this figure is to show an example of an implementation of the invention. 

The terminal is turned on in step V . The existence of a new version is notified in step 
4* If there is a new version, the current version is moved in step 6'. (If the current 
versionisaworkmg version it is stored, otherwise it is deleted). The new version is 
load ed in step 7' and started in step 5a'. In connection wim the startir^ mere is cr^ 
an object in step 9b' to indicate passing of the test performed in step 8'. THe passing 

l5 ofttetestisnotifWm^^ 

test is notpassed. In thatcasethe capability of functioning ofthe current version is 
notified in step T. In this embodiment, if an object exist, it is notified in step 2" if 
this is the second try of bootir^ me software. (TTus can be notified by updating the 

objectmsuefcawaymeveryt^ 
20 r doadedmste P 4a%ifms1ep2^it was notified that th^ 

booting. 

Ifstepr' showed that this was not tJies^ndtry.itbnotifiedmstepr". if anold 
current version exists e.g. as Seated by the second memory 18 in figure 1 being 
25 loaded This can be notified for example with creating an own object for this purpose, 
ff this is the case, the old version is reloaded in step 4" and started and tested m step 
5c' also comprising the creation of a new object The passing of the test is notified m 

, f . rtKW t deleted in step 9d' and the current software 
step 2c*. If the testis passed, the object is aeiexea in j>ic H ^ 

version can be used. 

If it was notified in step 2C, that the test was not passed, the current object is updated 
in step 9e' to indicate in a subsequent execution of step 2", a second try. A restart, 
manual or automatical, is thereafter carried out in step lb'. 
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If according m step 2'", there is no older working version, the basic version is # 
reloaded in step 4a'. Program execution then-proceeds from steps 5b', 9b' by testrng 
the reloaded basic version. 

If according to step 2'. there is no object, it means that the current version is working 
and it is started in steps 5b'. An object is created in step 9a', which is deleted m step 
9c' if the test according to step 8a' is passed, after which the program is ready for use. 

If the test is not passed in step 2a', a restart is carried out in step lb'. 

Ifthereisnonewv^onofsoftwareavaUablea^ 
2\ which is explained above- 

Figure 5 is a detailed example of a functionaUty test performed for the current 
software in the terminal in connection wim ^starting in step 5. An object 52 ^ 
created in step 51 A. The functionaUty of the version of the software is tested by 
setting a number of checkpoints CI, C2, C3 called checkpoint 1 . checkpoint 2 and 
checkpomt3mfigure5,tr^ 

step 53 in the object 52. The number of checkpoints can vary, but for illustrate 

pulses, there ^^Ub^*^^^***^'*"^ 
in the program and copied to the object 52 at an early, phase of program execuuor, 



15 



25 



30 



^checkpoint can for example ^cM*^********!™*** 1 - 
to be passed. In figure 5, only one thread is described. Other alternatives are also 
possible and they are chosen depending on the program A checkpoint counter 54 can 
beusedmmeobje^forcountingmech^ 

is passed, the counter number is increased by one. In figure 5 , there has been 
Ulustrated the case, wherein all three checkpoints has been passed. 

The number of checkpoints passed is compared to the defined amount in step 55, and 
if ,he number of checkpoints defined in the object is equal to the number of 
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checkpoints passed according to the counter, the test is passed as indicated by W<? 
and the software is ready for use. If the number defined in the object is not equal to 
the number of checkpoints passed, in this embodiment, the old object is updated m 
step 57 or a new object is created. 
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CLAIMS 

, Am «hooofoo— 

^ y, works as the current version, 
of the software, one of which wonts as, 

,.r. a racterizedbythestepsof 

b) opuo y, „ f th< . software to be downloaded as a possible result 

c) selecting another version of the software 10 oc 

of the software, one of which works as the current version, 
in the radio tenninal, 

of a new version of the software, 
M notifying a possible existence ota new vw* 
23 ^alea^ooof^soft^^.^o^^conea, 

ve^r^^orifftaereiaa^veasiooofftaeaoftvrare.^ 
, ^U.ecaraeo.veaaiooofftaeaoftw^befcreanewveraioou 
oowolo^iflhecu^tverfonia.^Atagvemoo, 

, e, t ^ m *-~-**"-'*—-*—«~ m 
„dio temunal to be the current .enuon, 
0 ^ the c^ab..,* of throng of ore cunen, «*. of .he software 

step a) or step e), and 
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g) fcdicatingtheres^^ 

functioning of said tested version of the software can be determined. 

A method of downloading software into aradio terminal having at least two pieces 
of the software, one of which works as the current version, 
characterized by the steps of 

a) determining the capability of functioning of the current version of the software 

in the radio terminal, 
c) selecting another version of the software to be downloaded if the cunent 

version does not work, 

e) downloading of the other version of the software selected in step b) into the 

radio terminal to be the current version, 

f) testingthecapabmtyo^ 
step a) or step c), and 

g) indicanngmeresultof^ 

functioning of said tested version of the software can be determined. 

4 Methodofclaiml.characterized in that in step d), the current version is 
stored before a new version is downloaded if the current version according to step 
a) is a working version. 

5 Methodofclaiml.characterized bythestepsof 
a) detenniiungthecapabmtyof^ 

in the radio terminal, 
c) selecting another version of the software to be downloaded if the current 

version is not a working version according to step a), 
e) downloading of the other version of the software selected in step c) into the 

radio terminal to be the current version, 
0 testing the capability of functioning of the current version of the software of 

step e), and 

g) indicating the result of said test in such a form that the capability of 
functioning of said tested version of the software can be determined. 
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Mahodof c ta ta».ch.r.c.er i2 edb,*e S «cpsof 

in the radio terminal, 
„) oo^ipossiblc^i^ofa^vemonof^sof^bef^orrfte, 

of step a) orb), 

d) storing the current version of the software, before a new versron » 

downloaded, if the current version according to step a) is a woriong versron, 
c) downloadingoftheotherversionoftiresoftware 

radio terminal to be the current version, 
f) after step a), or e), testing the capabdity of funcnonrng of the current vers.cn 

of the software of step a) or step e), and 
B) indicating'the^ 

functioning of said tested version of the software can be detennined. 

7 Method ofany of churnsl-^characterized ur that the uresis repeal 
until there is a working version of the software in the radio ternunal. 

8 Mcmodofanyofclaunsl-T.characterixed inthatthecapabuityof 
functioningof a current version is tested and detennined at least once. 

, M eu^ofa,yofclaimsl-8,characterized in that steps a) -g) are 
carried out each time the mobile phone is turned on. 

Method of any of claims I -9, characterized m that the number of 
versions stored in theradio terminal is selected by deleting one or more of the 



9 



10. 

older versions. 



^ofdaim ^characterized in dra. ft. nunrber of -ions st^ed 

i„ *. radio .ennmal « — «- W °°* " mWe ** M " Va5,0nS - 

recording as new versions are installed. 
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12.Methodofanyofclairnsl-2,4,6-ll.characterizedinthatin ! 

other version selected to be downloaded is a new version of the software if such a 
new version exist according to step b). 

5 13 Method of any of claimsl-H.characterized in that in step c) the other 
version of the software selected to be downloaded is an earlier stored older 
version, if according to step a), the current version is not working. 

14 Methodofanyofclairnsl-U.characterized in that in step c) the other 
l0 version of the software selected to be downloaded is an earlier stored older 

version, preferably the foregoing working version stored, if according to step a), 
the current version is not working and according to step b), there is no new version 
available. 

15 15 Memcdofanyofc^^ 

version of the software selected to be downloaded is a basic version stored in 
ROM ifthat is the foregoing stored working version or if the method is repeated 
^nta tot is the only working version of the software in the radio terminal. 

20 i6.Methodofanyofclaimsl-U,characterized in that in step c), the other 
version of the software selected to be downloaded is downloaded from the 
manufacturer's server. 

,7 Memod of anyof churns 1 - 16.char.cerized in dash, aep0.lhe.es uUof 

software summon to .he mobile phone b, means of which indicator the capability 
of fummoning of the cunent version of the software in the mobile phone ts 
notified in step a). 

w 18 . Me d M dofcUdtnl7,ch,r,c.«riz«dinma.ms K pg),u 1 ecapabni V of 

Zoning of said current vention of the softwe is mdtcattd by the absence of 
aid special Indicator and the opposite situation with the ptesenc of satd 
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indicator, which is removed when, according to the test, a working versionl*«fc2t 
software has been started. 

19. Method of claim ^characterized in that in step g), the capability of 
5 functioing of said current version of the software is indicated by the absence of 
said special indicator and the opposite situation with the presence of said 
indicator, which is updated every time step g) is carried out to show the number of 
tests performed. 

10 20.Methodofclaiml9,characterized in that the other version of software 
selected to be downloaded is selected in step c) on the basis of the updated 
indicator. 

21.Method of claim ^characterized in that in step g), the capability of 
functioning of said current version of the software is indicated by the absence of 
said special indicator and the opposite situation with the presence of said 
indicator, which is updated every time step g) is carried out so that the current 
version of the software can be identified. 



is 
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22.Memodofanyofclaimsl7-20,characterized in that said special 
indicator is made in such a form that the current version of the software can be 
identified. 

^.MeAodofanyofclainul?^ 
25 form of an ordinary file. 

24.Memodofanyofclaimsl-23,characterized in that in step f), the 

capability of functioning of said current version of the software is tested by setting 
a number of checkpoints the software should pass to start up correctly as a 
30 working version. 
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25. Method of claim 24, characterized in that each checkpoint is made^^ 
of one critical point per thread in the software or per terminal resource in the 
software that has to be passed. 

5 26. Meth«lofclajm24 or 25, characterized in thatin the testing of step 0, the 
following steps are included 

notifying each checkpoint passed with a checkpoint counter, 
checking the number of checkpoints, and 

indicating the tested version of software as a working version in step g) if the 
10 number of checkpoints in the checkpoint counter correspond to the number of 
checkpoints to be passed. 

27. Memod of any of claims I -26, characterized in that in step d), the 
current version is stored by packing it with a compressing program to reduce the 

15 amount of space required on the phone. 

28. Method of any of claims 1-27, characterized in that said radio tenninal is 
a mobile phone. 

20 29. Radio tenninal having at Least two pieces of software, one of which works as the 
current version, c h a r a c t e r i z e d by means for 

a) checking the capability of functioning of the current version of the software in 
the radio terminal, 

b) notifying a possible existence of a new version of the software, 

25 c) selecting another version of software to be downloaded to replace the current 
version, 

d) storing the current version of the software, 

e) downloading another version of the software into the radio terminal to be the 
current version, 

30 0 testing the capability of functioning of the current 
of 

g) indicating the result of said test in such a form that the capability of 
: functioning of said tested version of the software can be checked. 
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30. Radio tcnninal of claim 29,characterized in that there is one or more 
woiking versions stored. 

5 31.RadiotermmaIofclaim30,characteri2ed in that one ofthe versions of the 
software stored is a basic version stored in ROM. 

32. Radio terminal of any of claims 29 -31, char ace ri zed bymeansfor 
indicating thcresult of said test by the presence orabsence of a special indicator to 

10 show the software situation in the radio terminal. 

33. Ramotermmalofclaim32,characterized by means for updating the 
indicator every time said test is repeated to show the number of tests performed. 

34. Ramotenninalofclaim32,characterized by means for creating said 
special indicator in such a form that the current version of the software can be 
identified. 

35. Ramotennmalofanyofclaims2904,chara^ by means for 
20 creating said indicator in form of an ordinary file. 

36. Radio terminal of any of claims 29-35,character ized by means for 
testing the current version of the software by setting a number of checkpoints the 
software should pass to start up correctly as a working version. 
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37. Radio terminal of claim 36,character ized by 
a checkpoint counter notifying each checkpoint passed , 
means forchecking the number of checkpoints, and 

means for indicating the test result in accordance with the number of checkpoints 



30 
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38. Radio terminal of any of claims 29 - 37, c h a r a c t e r i z e d by means for 
storing the current version by packing it with a compressing program to reduce the 
amount of space required on the phone. 

39. Radio terminal of any of claims 29 - 38, c h a r a c t e r i z e d in that it is a mobile 
phone. 
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